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BACKGROUND OF THE INVENTION 

Field of the Invention 

This invention relates to configuring a computer for installation of a 
peripheral device. In particular, device drivers are selected for computer 
peripherals, based upon an identification code associated with the peripheral. 

Description of the Related Art 

Most personal computer (PC) systems facilitate the installation of 
newly connected hardware devices by first detecting that the new device has 
been connected to a bus of the computer. For example, the Microsoft® 
Windows® "Install New Hardware Wizard," may be activated by a user to 
assist in detecting and identifying the newly connected hardware. The 
Hardware Wizard recognizes newly connected hardware, and guides the user 
through the installation of the correct device drivers. A device driver is a 
software program that matches standardized commands from the computer's 
operating system to specific capabilities of the newly connected device. To 
aid in this process, Microsoft® Windows®, for example, uses a popular 
software routine called Plug and Play. 

Plug and Play is a computer implemented routine that provides a host 
PC with an ability to detect the connection of new hardware, and in some 
cases, to automatically install the required device driver(s). Specifically, Plug 
and Play, implemented by the PC's operating system, identifies new hardware 
devices connected to the PC and presents the user with installation options. 
Most new PCs are Plug and Play compatible. 
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In order for Plug and Play to function, the new hardware device must 
also be Plug and Play compatible. A major component of this compatibility is 
the Plug and Play device's identification (ID) stored in a memory location of 
the newly connected hardware device. This ID is provided to the PC during a 
5 Plug and Play handshake session. Plug and Play operates by requesting that a 
newly connected hardware device identify itself to the PC using the ID. In 
response, the device transmits its device ID to the PC which is then processed 
and identified by the PC's operating system. The signaling standard that 
governs the physical and electrical exchanges between the PC and the newly 

10 connected hardware device is the IEEE Std. 1284-1994 Standard Signaling 
Method for a Bi-directional Parallel Peripheral Interface for Personal 
Computers, published March 30, 1994. 

The IEEE 1284 standard essentially upgrades the standard parallel port 
(SPP) interface that was designed for the IBM PC of the early 1980s. In 

15 particular, IEEE 1284 defines the physical and electrical interface between the 
PC and the peripheral device. The original SPP, referred to as the Centronics 
style interface, provided an input/output (I/O) interface between a PC and a 
peripheral device at speeds on the order of 150 KBps. During this time frame, 
the fastest peripheral device was the dot matrix printer which could be easily 

20 accommodated by the SPP. The Centronics style SPP, however, was unable to 
accommodate the much faster peripheral devices of modern personal 
computing, such as laser printers, which transfer color graphic files of sizes on 
the order of megabytes. An additional short-coming of the earlier parallel 
ports was the limitation of being able to transfer information in one direction 

25 only. Therefore, in the mid-1990s, the IEEE Standards Board approved the 
IEEE 1284 signaling method. 

IEEE 1284 parallel ports run at 100 to 200 times faster than the 
original Centronics- style parallel ports and not only facilitate faster 
communication, but also facilitate bi-directional communication, allowing the 
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printer to not only receive data, but also talk back to the PC. Today, most 
printer manufacturers design their newer generation printers to support the 
IEEE 1284 signaling standard. The device drivers that accompany these 
machines take full advantage of the high speed data rates and the bi-directional 
5 capability provided by IEEE 1284. 

As shown in Fig. 1, IEEE 1284 defines five modes 15-19 of data 
transfer. The original Centronics SPP included 17 signal lines and 8 ground 
lines. The signal lines included control lines for providing interface control, 
status lines for providing status indications for things such a paper empty 

10 signals, and data lines used to transfer data between the PC and the peripheral. 
IEEE 1284 uses these same data lines but redefines the electrical 
characteristics and signaling protocol required for communication. The first 
three data transfer modes of IEEE 1284, the compatibility mode 15, nibble 
mode 16, and byte mode 17, are provided mainly to support older uni- 

15 directional devices that continue to operate at the slower speeds. The 

Enhanced Parallel Port (EPP) mode 18 and Extended Capability Port (ECP) 
19, facilitate operation of more modern, faster peripheral devices. EPP mode 
primarily supports CD ROMs, hard drives, and other non-printer peripherals 
and ECP mode is mainly directed towards printers and scanners. Microsoft® 

20 Windows® 95, for example, supports each of the five IEEE 1284 data transfer 
modes in its Plug and Play routine. 

IEEE 1284 also defines the requirements of the device ID used, for 
example, in the Plug and Play implementation. As addressed above, the 
device ID is requested from the new hardware device by the PC in order for 

25 the PC to be able to properly identify and install the device drivers necessary 
for the new hardware to function correctly. In accordance with IEEE 1284, the 
device ID includes specific case sensitive key values. These values includes 
fields such as MANUFACTURER, and MODEL which are abbreviated by 
IEEE 1284 as MFG, and MDL respectively. The MFG identifies the device 
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manufacturer, and MDL provides a specific model number or nomenclature. 
Other Key fields exist, such as CLASS (CLS) and DESCRIPTION (DBS), but 
are not as widely used. All ID key values must consist of American Standard 
Code for Information Interchange (ASCII) values of 32-127 (20h-7Fh) and are 
5 stored in the newly connected peripheral's configuration memory, such as 
ROM, or EEPROM, and stored in the form of an INF file. INF files typically 
contain all the data and information necessary to configure and operate the 
respective device. 

With Plug and Play implemented, a user is then able to implement 

10 routines such as the Microsoft® Install New Hardware Wizard, and navigate 
through the procedures required for the user to complete installation of the 
device. The problem is, however, that Plug and Play is not adequate to handle 
installation of all devices in all scenarios. One of the scenarios where Plug and 
Play is least helpful is installing shared printers in a networked PC 

15 environment. Specifically, Plug and Play will not identify, for example, a new 
printer added to a print server operating in a Novell computer network 
environment. 

Additionally, Plug and Play cannot presently apriorily determine 
whether a particular device installation will be problematic and thus cannot 
20 inform the user of any special measures necessary to resolve these problems in 
order to properly install the new hardware device. Therefore, a different 
technique is needed to resolve these types of problems and thus provide a user 
with the ability to successfully complete installation of a printer in a 
networked PC environment. 

25 

BRIEF DESCRIPTION OF THE DRAWINGS 

The accompanying drawings, which are incorporated in and constitute 
a part of the specification, illustrate embodiments of the invention and, 
together with the general description given above and the detailed description 
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of the embodiments given below, serve to explain the principles of the 
invention. 

Fig. 1 is a chart illustrating each of the modes of IEEE Std. 1284. 
Fig. 2 is a diagram of an exemplary PC with a scanner and printer 
5 attached. 

Fig. 3 is a diagram of the PC of Fig. 2 networked with other PCs. 
Fig. 4 is a diagram of the PC of Fig. 2 networked with other PCs and 
an additional printer. 

Fig. 5 is a flow chart describing an exemplary method of implementing 
10 the present invention. 

Fig. 6 is a flow chart of the ID read process of Fig. 5. 
Fig. 7 is a flow chart of the translation/comparison process of Fig. 5. 
Fig. 8 is an illustration of exemplary contents of a peripheral device's 
INF file, an example of a concatenated ID string, and an example of a host 
15 device's INF file contents. 

Fig. 9 is a flow chart of the process of installing a previously installed 
printer at a different workstation. 



DETAILED DESCRIPTION 

20 An embodiment of the present application retrieves an IEEE 1284 

device ID from any peripheral device that supports the IEEE 1284 signaling 
standard. It extracts manufacturer and model information from the device ID 
stored e.g., in a printer, and translates it into the manufacturer and model name 
used by the Microsoft® Windows® operating system, for example, in its 

25 printer selection process. The manufacturer and model names are then used in 
order to select the proper software driver required to complete the installation 
of the new hardware device. 

In Fig. 2, a PC workstation 2 includes a stand-alone PC 5 with a 
peripheral device attached, such as a scanner 4. If a user desires to attach a 



printer 6 to the PC 5, workstation 2B is created. In order to successfully 
connect the printer 6, an operating system used by the processor of the PC 5 
may use a routine such as the Microsoft® Install New Hardware Wizard, 
previously described. 

A user would initiate installation by first connecting the new hardware 
and then activating the Hardware Wizard routine. The routine would assist the 
user in identifying the newly connected printer 6, and provide the user with a 
list of potentially matching drivers from which to choose. A processor of the 
PC 5 would attempt to match the device ID of printer 6 to a list of device 
drivers stored in its own memory. If a match occurs, the device driver will be 
selected in order to facilitate installation. If no match is found, the user is then 
permitted to either provide a diskette containing the proper device driver, or 
select a driver from the list of drivers. 

In Fig. 3, for example, PCs 5, 7, and 9 are connected to one another 
using a connection medium 8 to form a computer network 12. A printer server 
10 is also connected to the network for the purpose of allocating the use of 
printer 6 between each of the PCs 5, 7, and 9. In this arrangement, the printer 
6 is not directly attached to a PC but is attached to the print server 10 instead. 
In the configuration of Fig. 3, if the user desires to add an additional printer 
1 1, as shown in Fig. 4, the Hardware Wizard cannot be used by the PC 5 user 
to install the additional printer 11. This routine cannot be used because, as 
stated earlier, printer 6 is not attached directly to a PC but is attached instead, 
to the print server 10. Similarly, new printer 1 1 is also be connected to the 
print server 10. Since the Hardware Wizard, Plug and Play, and other similar 
routines, are designed for stand alone PC operation, none of the PCs 5, 7, or 9, 
would be able to detect and select the proper driver for installation of newly 
added printer 1 1. In short, the print server 10 would not be able to 
automatically select a driver for the newly added printer 1 1 without the aid of 
some other device or method. 



By providing, for example, the print server 10 and the PC 5, of Fig. 4, 
with an exemplary embodiment of the present invention, such as illustrated in 
selection/installation process 50 of Fig. 5, the user would be able to connect 
new hardware to the computer network 12 and be able to install the necessary 
drivers. The user is also informed, beforehand, whether a particular 
installation will present problems. Thus, by using the aforementioned 
exemplary embodiment of the present invention, the user can automatically 
select a device driver, such as a printer driver required for printer 11, and 
resolve these potential installation problems. 

In Fig. 5, the operating system of PC 5 along with the present 
invention 50, would first recognize 100 that a new device has been installed on 
the output port of the print server 10. The user would then be prompted as to 
whether installation of the new device should be attempted 102. If installation 
is desired, the routine, partially stored in a memory of PC 5 and print server 
10, would proceed to read 200 the IEEE 1284 device ID from the newly 
connected device, e.g., printer 1 1 . If device installation is not desired, the 
process would tterminate 700. 

In order for the print server 10 to read the IEEE 1284 device ID from a 
newly added peripheral, such as printer 1 1, the print server 10 must first 
transmit a read request 200A data signal, as shown in Fig. 6. Transmission of 
this signal will ultimately determine whether the printer 1 1 is IEEE 1284 
compatible 200B. If compatibility is confirmed, the printer's device ID is 
retrieved 200C and stored in an appropriate memory location. 

As addressed earlier, the device ID may be found in the memory of 
printer 1 1 as a string of ASCII characters between the values of 20h-7Fh, and 
may comprise key values such as MFG, MDL, CLS, and DES. The idea of 
the present invention is that the ID string, comprising at least the MFG and 
MDL key values, may be manipulated in a number of different ways to assist 
in identification of the drivers of a shared peripheral. However, in the 
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exemplary embodiment illustrated in Fig. 5, not all of the key values are used 
by selection/installation process 50. 

When these fields are received and stored 200D, the routine 50 will 
then attempt to compare 300 the ID to a list of device drivers stored in an INF 
5 file of the PC 5. The invention may be implemented by manipulating any of 
the IEEE 1284 ID key fields and comparing these manipulated fields with 
stored device data. However, as shown in Fig. 7, the MFG and MDL key 
values are the primary key values used. First, upon retrieval, the MFG and 
MDL values are directly compared 300A with device names on a list of device 

10 drivers stored in PC 5. If a match 300B is found, the matching driver is 
selected 400. On the other hand if the comparison between the MFG and 
MDL key values with the listed names does not produce a match, the MFG 
and MDL key values are concatenated 300C, i.e., they are combined to form 
an ID string. The concatenated ID string is then compared 300D to the same 

15 list of drivers. Again, if a match 300E is found, the matching driver is selected 
400. If a match 300E is not found, the MFG key value is then removed 300F, 
leaving the MDL as the remaining key value in the ID string. Finally, the 
MDL key value is compared with the list 300G in order to find a match 380. 
If a match 380 is found, the matching driver is selected. However, at this 

20 point, if a match is not found, the process will not be able to automatically 

select the appropriate driver. The translations that occur at 300C and 300F are 
necessary because the device ID codes, as stored in the printer 1 1, do not map 
directly into the device ID display strings associated with the device drivers. 
For example, Fig. 8 illustrates the manner in which typical MFG and MDL 

25 codes would appear in a file 30 stored in a memory of the printer 1 1 . The 
MFG field may contain the value "printer-maker" minus the quotes to denote 
the manufacturer of the printer, as shown in Fig. 8. The MDL field may 
contain the value "PM Laserjet 3T" minus the quotes, to denote the specific 
model of the printer. 
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In the example of Fig. 8, after the MFG and MDL key fields have been 
retrieved and compared 300 with the list of drivers, the selection/installation 
process 50 will then concatenate the two key values 300B, producing "printer- 
makerPM_9876, 32." This value is then compared to names on the list of 
drivers stored in a file 34 of the user's PC. Although the MFG and MDL 
fields are utilized in the present invention, it is possible, as stated above, that 
other key field values may be used to create the device ID, such as a 
compatibility (CID) key field. The CID key field informs a Microsoft® 
Windows® based processor if the peripheral device will emulate other 
devices. When a match is finally achieved, a device driver is selected 400. 

Again referring to Fig. 5, after selection of the device driver, the 
installation/selection routine 50 would determine if the particular peripheral 
device and the corresponding selected driver have historically created 
installation problems 500 for users. This feature is implemented by compiling 
known information into a data file, storing the information in database 501 in 
the print server 10, and making this information available to users. The 
selected driver is then compared with the database 501 to determine if the 
present installation is even possible, and/or determine if historical problems 
exist with respect to this particular installation. For example, some printers are 
considered to be host-based devices. That is, in order for these printers to 
initially be set-up for use, for example to have the printer heads properly 
configured and the printer's ink flow adjusted, they must be first attached to a 
local PC. A user would not be able connect such a host-based printer to a 
network without having first configured the printer by connecting it to a host 
PC. Additionally, some printers will simply not work unless they are 
connected directly to a host workstation. This type of information is 
particularly helpful to prevent the user from wasting time trying to accomplish 
device installations that will be problematic at best, if not impossible. This 
type of information is stored in database 501 . Finally, the information is 



presented to the user along with information required to resolve the 
installation problems 600, so that the device driver can be properly installed. 
The user is now able to install 650 the device driver and store information 
related to the particular installation in a memory of the print server 840. This 
5 process ends at 700 after the correct driver has been selected with the user able 
to install the selected driver in the PC 5. 

In another embodiment of the present invention, subsequent users of 
workstations connected to network 12 may also desire to configure their PC 5 
for installation of the newly connected printer 1 1. These users may benefit 

10 from previous installation information 840 of the routine 800, illustrated in 
Fig. 9. This information is stored after the first installation of a newly 
connected printer associated with print server 10 and network 12. That is, all 
the steps and information taken by the user that first installed printer 11, can 
be made available to all subsequent network users desiring to also install the 

15 proper device drivers in their PC in order to print to the same printer 1 1. 

Included, is information such as the specific driver(s) selected, the reference 
name of the printer, as well as other relevant information. Since this 
information is available to the user, the remainder of the installation process, 
for this particular user, can be simplified. Simplification is necessary because 

20 sometimes the 1284 codes are incomplete or inaccurate. 

To implement the process, the routine 800, would first read the 1284 
device IDs from the peripheral device, as executed in block 200 of Fig. 5. 
Next, it is determined 810, based upon the ID, whether a current desired 
installation is the first installation of the printer 1 1 involving the particular port 

25 of print server 10. If the current installation is the first time printer 1 1 has 
been installed at this particular port of the print server 10, i.e. the first 
installation, the process executes blocks 300, 380, 400, 500, and 600 from Fig. 
5. This series of executed functions permit the user to install 820 printer 1 1 
and store pertinent information, relating to this installation, in a memory of the 
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print server 840. On the other hand, if the current installation is not the first 
installation, i.e., this is not the first time printer 1 1 has been installed at the 
port of print server 10, the user will be presented with the information that was 
used to install the printer 1 1 during the earlier installation 830. This 
5 information is retrieved from a memory 840 of the print server 10. 

In order to verify that printer 1 1 was indeed previously installed and 
not some other device, the IEEE 1284 ID of the previous installation, is 
retrieved from the stored information 840. If the IEEE 1284 ID of the current 
installation matches the ID of the earlier installation 850, confirmation is 

10 established that the current printer 1 1 was the device previously installed at the 
particular port of print server 10. In this case, the benefit of the previous user 
information, retrieved at 830, is used and installation of the printer 1 1 is 
completed by executing block 380 of process 50 and continuing. However, if 
the comparison of the IEEE 1284 IDs 850, did not produce a match, 

15 installation of the drivers would be completed based upon steps 400-600 of 
Fig. 5. If the IEEE 1284 IDs did not match, this would be an indication that 
the printer 11, had been changed since the previous installation of the device 
driver drivers. The user would then be permitted to select and install the 
required printer (driver) and then store relevant installation information in the 

20 database 840. This stored information is in-turn, made available to subsequent 
users. 

The advantage of this process is that once one workstation has been 
configured to print to a particular printer, other users of workstations in the 
same office, connected to the network 12, will have simplified set-up 
25 procedures, based upon the information of the earlier installation. 

From the invention thus described, it will be obvious that the invention 
may be varied in many ways. Such variations are not to be regarded as a 
departure from the spirit and scope of the invention, and all such modifications 
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as would be obvious to one skilled in the art are intended for inclusion within 
the scope of the following claims. 
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WHAT IS CLAIMED IS: 

1. A method of configuring a computer for installation of a peripheral 
device, the method comprising: 

preparing a print server to retrieve a first device identification from a 
memory of the peripheral device, the print server, the peripheral device, and 
the computer being connected via a computer network; 

comparing the first device identification to device names on a list of 
names associated with device drivers, the list and the drivers being stored in a 
memory of the computer; and 

selecting for use an associated driver if the first device identification 
matches one of the names. 

2. A method according to claim 1 further comprising: 
translating the first device identification into at least a second device 

identification if the first device identification does not match one of the names; 

comparing the at least second device identification to the device 
names; and 

selecting a driver from the list if the at least second device 
identification matches one of the names. 

3. A method according to claim 2 further comprising: 
determining whether the peripheral device requires special measures in 

order to install the selected device driver; 

identifying an appropriate special measure from a database of potential 
special measures stored in a memory of the print server; and 

informing a user of the appropriate special measure. 

4. A method according to claim 2 further comprising alerting a user if 
the second device identification does not match one of the names. 
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5. A method according to claim 1 wherein the peripheral device is a 

printer. 

6. A method according to claim 1 wherein the computer network is 
compatible with the Microsoft® Windows® Operating System. 

7. A method according to claim 2 wherein the device identifications 
conform to an IEEE 1284 signaling standard. 

8. A method according to claim 7 wherein the first device 
identification includes at least manufacturer and model key values. 

9. A method according to claim 7 wherein the first device 
identification includes a compatibility identification key field. 

10. A method according to claim 1 wherein the selecting occurs 
automatically. 

1 1. A method according to claim 2 wherein the translating includes a 
database look-up. 

12. A method according to claim 8 wherein the translating includes a 
database look-up using alternate names and key values. 

13. A method according to claim 8 wherein the translating includes 
concatenating the manufacturer and model key values. 
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14. A method according to claim 8 wherein translating further includes 
removing the manufacturer key value. 

15. An apparatus comprising: 

a computer network including a number of computer devices 
connected thereto, the computer devices including a print server, a computer, 
and at least one printer; 

a memory in the at least one printer for storing a first printer 
identification data string; and 

a processor associated with the computer including (i) a comparator for 
comparing the first data string to a device name on a list of device drivers 
stored in a memory of the computer, and (ii) a selector selecting a driver from 
the list if the first identification data string matches one of the names. 

16. An apparatus according to claim 15, further comprising: 

a translator translating the first identification data string into at least a 
second identification data string if the first identification data string does not 
match one of the names; 

wherein the comparator compares the at least second identification 
data string to the device names and the selector selects a driver from the list if 
the at least second identification data string matches one of the names. 

17. An apparatus according to claim 16, further comprising: 

a determination mechanism for determining whether the printer 
requires special measures in order to install the selected device driver; 

a database stored in a computer memory of the print server and 
including a number of special measures; 

wherein the determination mechanism identifies an appropriate special 
measure from among the number of special measures; and 
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an informing mechanism for informing a user of the appropriate 
special measure. 

18. An apparatus according to claim 16, further comprising: 

an alerting mechanism for alerting a user if the second identification 
data string does not match one of the names. 

19. An apparatus according to claim 15 wherein the computer network 
is compatible with the Microsoft® Windows® Operating System. 

20. An apparatus according to claim 16 wherein the device 
identification strings conform to an IEEE 1284 signaling standard. 

21. An apparatus according to claim 20 wherein the first device 
identification data string includes at least manufacturer and model key values. 

22. An apparatus according to claim 16 wherein the translator searches 
a database. 

23. An apparatus according to claim 20 wherein the translator searches 
a database and uses alternate key values. 

24. An apparatus according to claim 20 wherein the identification 
string includes a compatibility identification key value. 

25. An apparatus according to claim 21 wherein the translator 
concatenates the manufacturer and model key values. 
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26. An apparatus according to claim 25 wherein the translator removes 
the manufacturer key value from the identification data string. 

27. A method of installing printer drivers in a computer of a computer 
system, the computer system also including a printer and a print server, the 
computer, the printer, and the print server being connected via a computer 
network, the method comprising: 

preparing the print server to determine if a current installation of the 
printer drivers is a first installation of the printer drivers; 

installing the printer drivers in the computer if the current installation 
is the first installation and storing information associated with the current 
installation in a memory of the print server; 

retrieving information associated with the first installation from the 
memory if the current installation is not the first installation, the information 
associated with the first installation including a first identification data string; 

retrieving a current identification data string from a memory of the 
printer, the current identification data string being associated with the current 
installation; 

comparing the first data string with the current data string; and 
installing the printer drivers in the computer based upon the 

information associated with the first installation if the first data string matches 

the current data string. 

28. A method according to claim 27 further comprising installing the 
printer drivers in the computer if the first data string does not match the 
current data string and storing information associated with the installing, when 
the first data string does not match the current identification string, in the 
memory of the print server. 
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29. A method according to claim 27 wherein the first and current data 
strings are IEEE 1284 ID data strings. 

30. An article of manufacture comprising a machine-readable medium 
having recorded thereon instructions, such that when the instructions are read 
into a memory of a computer processor and executed, the instructions cause 
the computer processor to: 

retrieve a first device identification from a memory of a peripheral 
device, the computer processor, the peripheral device, and a computer being 
connected via a computer network; 

compare the first device identification to device names on a list of 
names associated with device drivers, the list stored in a memory of the 
computer; and 

select for use an associated driver from the list if the first device 
identification matches one of the names. 
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ABSTRACT OF THE DISCLOSURE 

A method and system for automatically configuring a computer 
peripheral device connected to a computer network. The method and system 
both retrieve the Industry of Electrical and Electronic Engineering standard 
1284 device identification stored in the peripheral device and select an 
appropriate device driver for installation of the device. Upon completion of an 
initial device driver installation, a subsequent user is provided with 
information pertaining to a previous installation of the driver in order to 
simplify a current installation of the driver. 
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